﻿using System;
using System.Collections.Generic;
using System.Linq;
using Controller2.BLL;

namespace Controller2.Models.ViewModels
{
    public class MidiaViewModel
    {
        public int ID { get; set; }
        public string Nome { get; set; }
        public string Veiculo { get; set; }
        public string Valor { get; set; }

        public IEnumerable<MidiaViewModel> Listar(ControllerBDModelContainer db, string texto, int filtro)
        {
            IEnumerable<MidiaViewModel> mid;
            int codigo = 0;
            if (filtro == 1)
            {
                if (!Int32.TryParse(texto, out codigo))
                {
                    filtro = 0;
                    texto = "";
                }
            }
            if (string.IsNullOrWhiteSpace(texto) || texto.Equals("Digite sua pesquisa"))
            {
                filtro = 0;
                texto = "";
            }
            switch (filtro)
            {
                default:
                    mid = from m in MidiaBll.GetAllMidias(db)
                          orderby m.IdMidia
                          select new MidiaViewModel
                          {
                              ID = m.IdMidia,
                              Nome = m.Nome,
                              Veiculo = m.Veiculo.Nome,
                              Valor = m.Valor.ToString("N2")
                          };
                    break;
                case 1:
                    mid = from m in MidiaBll.GetAllMidias(db)
                          orderby m.IdMidia
                          where m.IdMidia == codigo
                          select new MidiaViewModel
                          {
                              ID = m.IdMidia,
                              Nome = m.Nome,
                              Veiculo = m.Veiculo.Nome,
                              Valor = m.Valor.ToString("N2")
                          };
                    break;
                case 2:
                    mid = from m in MidiaBll.GetAllMidias(db)
                          orderby m.IdMidia
                          where m.Nome.Contains(texto)
                          select new MidiaViewModel
                          {
                              ID = m.IdMidia,
                              Nome = m.Nome,
                              Veiculo = m.Veiculo.Nome,
                              Valor = m.Valor.ToString("N2")
                          };
                    break;
                case 3:
                    mid = from m in MidiaBll.GetAllMidias(db)
                          orderby m.IdMidia
                          where m.Veiculo.Nome.Contains(texto)
                          select new MidiaViewModel
                          {
                              ID = m.IdMidia,
                              Nome = m.Nome,
                              Veiculo = m.Veiculo.Nome,
                              Valor = m.Valor.ToString("N2")
                          };
                    break;
            }

			return mid.OrderBy(o => o.ID);
        }
    }
}